<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      // js异步执行顺序问题 ；
      function fn1(cb) {
        setTimeout(() => {
          console.log("fn1");
          cb && cb(); // 容错
        }, 1000);
      }

      function fn2(cb) {
        setTimeout(() => {
          console.log("fn2");
          cb && cb();
        }, 1000);
      }

      function fn3(cb) {
        setTimeout(() => {
          console.log("fn3");
          cb && cb();
        }, 1000);
      }

      // 三个运行结果一起显示，没有先后顺序
      // fn1();
      // fn2();
      // fn3();

      // 通过回调函数控制 异步的执行顺序 ；
      // 回调地狱：回调函数出现层层嵌套；写法不够优雅，可维护性差。
      fn1(function () {
        console.log("fn1执行完毕了");
        fn2(function () {
          console.log("fn2执行完毕了");
          fn3(function () {
            console.log("fn3执行完毕了");
          });
        });
      });
    </script>
  </body>
</html>
